package com.ruoyi.graduate.domain.entity;

import com.baomidou.mybatisplus.annotation.*;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
import org.springframework.format.annotation.DateTimeFormat;

import java.math.BigDecimal;
import java.time.LocalDateTime;

/**
 * <p>
 * 约拍订单表实体类（关联《毕设.doc》约拍管理/接单管理）
 * </p>
 *
 * @author [开发者名称]
 * @since 2025-11-09
 */
@Data
@ApiModel("约拍订单表")
@TableName("ms_photography_order") // 映射数据库表名
public class MsPhotographyOrder {

    @ApiModelProperty(value = "订单内部唯一标识（自增）")
    @TableId(type = IdType.AUTO) // 对应数据库AUTO_INCREMENT自增主键
    private Integer orderId;

    @ApiModelProperty(value = "订单编号（如YP20240501001，唯一，必填）")
    private String orderNo; // 对应数据库order_no字段（非空，唯一）

    @ApiModelProperty(value = "下单客户ID（外键，关联ms_sys_user表的user_id，必填）")
    private Long customerId; // 对应数据库customer_id字段（外键，非空）

    @ApiModelProperty(value = "接单摄影师ID（外键，关联ms_sys_user表的user_id，必填）")
    private Long photographerId; // 对应数据库photographer_id字段（外键，非空）

    @ApiModelProperty(value = "约拍时间（如2024-05-15 14:00，必填）")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    private LocalDateTime shootTime; // 对应数据库shoot_time字段（非空，datetime类型）

    @ApiModelProperty(value = "套餐价格（如3999.00，精确到两位小数）")
    private BigDecimal price; // 对应数据库price字段（decimal类型用BigDecimal映射，避免精度丢失）

    @ApiModelProperty(value = "拍摄类型（婚纱摄影/人像写真/商业拍摄等，必填）")
    private String shootType; // 对应数据库shoot_type字段（非空）

    @ApiModelProperty(value = "交付方式（电子版/精修/相册/相框等，逗号分隔，必填）")
    private String deliveryMethod; // 对应数据库delivery_method字段（非空）

    @ApiModelProperty(value = "订单状态：0=待确认，1=待处理，2=已接单，3=已完成，4=已取消（默认待确认）")
    private Integer orderStatus; // 对应数据库order_status字段，默认值0

    @ApiModelProperty(value = "拍摄主题（可选）")
    private String shootTopic; // 对应数据库shoot_topic字段（可选，默认空字符串）

    @ApiModelProperty(value = "拍摄地点（可选）")
    private String shootAddress; // 对应数据库shoot_address字段（可选，默认空字符串）

    @ApiModelProperty(value = "特殊要求（可选，含客户需求/拍摄要求）")
    private String specialReq; // 对应数据库special_req字段（text类型，可选）

    @ApiModelProperty(value = "备注信息（可选）")
    private String remarks; // 对应数据库remarks字段（可选，默认空字符串）

    @ApiModelProperty(value = "订单创建时间")
    @DateTimeFormat(pattern = "yyyy-MM-dd HH:mm:ss")
    @JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss", timezone = "GMT+8")
    @TableField(fill = FieldFill.INSERT) // 插入时自动填充（与表结构CURRENT_TIMESTAMP对应）
    private LocalDateTime createTime; // 对应数据库create_time字段（非空，默认当前时间）

}